home *** CD-ROM | disk | FTP | other *** search
/ PC Player 2004 May / pc player 2004-05.iso / Demos / FarCry / Data1.cab / _D04A709B9C2749DDB8348CB47F287558 < prev    next >
Encoding:
Text File  |  2004-01-06  |  1.9 KB  |  49 lines

  1.       #include "../CGVPMacro.csi"
  2.  
  3.       PS20Only
  4.  
  5.       MainInput { uniform sampler2D baseMap : texunit0,
  6.                   uniform sampler2D bumpMap : texunit1,
  7.                   uniform samplerCUBE projMap : texunit2,
  8.                   uniform sampler2D attenMap : texunit3,
  9.                   uniform sampler2D glossMap : texunit4,
  10.                   uniform float4 Ambient,
  11.                   uniform float4 Diffuse,
  12.                   uniform float4 Specular }
  13.       DeclarationsScript
  14.       {
  15.         OUT_T0_T1_T2_T3_T4_T5_T6_C0
  16.         FOUT
  17.       }
  18.       CoreScript
  19.       {
  20.         // load the decal
  21.         half4 decalColor = tex2D(baseMap, IN.Tex0.xy);
  22.         // load the bump normal
  23.         float4 bumpNormal = 2*(tex2D(bumpMap, IN.Tex1.xy)-0.5);
  24.         // load the projector filter map
  25.         half4 projColor = texCUBE(projMap, IN.Tex2.xyz);
  26.         // load the gloss
  27.         half4 glossColor = tex2D(glossMap, IN.Tex4.xy);
  28.         half atten = saturate((2*(IN.Color.b-0.5)) * -(2*(IN.Color.b-0.5)) + (1-tex2D(attenMap, IN.Tex3.xy).b));
  29.  
  30.         // normalize light vector
  31.         float3 lightVec = normalize(IN.Tex5.xyz);
  32.         float fDif = saturate(dot(lightVec.xyz, bumpNormal.xyz));
  33.  
  34.         // normalize view vector
  35.         float3 viewVec = normalize(IN.Tex6.xyz);
  36.         float3 reflVec = (2*dot(lightVec.xyz, bumpNormal.xyz)*bumpNormal.xyz)-lightVec.xyz;
  37.         float NdotR = saturate(dot(reflVec.xyz, viewVec.xyz));
  38.         half fSpec = pow(NdotR, Specular.w*glossColor.w);
  39.  
  40.         half3 dif = (decalColor.xyz * fDif * atten * Diffuse.xyz * projColor.xyz) * 2;
  41.         half3 spec = (fSpec * decalColor.w * atten * Specular.xyz * projColor.xyz) * 2;
  42.         half3 amb = Ambient.xyz * decalColor.xyz;
  43.  
  44.         // finally add them all together
  45.         OUT.Color.xyz = amb + dif + spec;
  46.         OUT.Color.w = Ambient.w;
  47.       }
  48.  
  49.